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Abstract 

The standard parameterization of the Vertex Cover problem (Given an undirected 
graph G and fc € N as input, does G have a vertex cover of size at most k?) has the solution 
size k as the parameter. The following more challenging parameterization of Vertex Cover 
stems from the observation that the size MM of a maximum matching of G lower-bounds 
the size of any vertex cover of G: Does G have a vertex cover of size at most MM + k^l The 
parameter is the excess of the solution size over the lower bound MM. 

Razgon and O’Sullivan (ICALP 2008) showed that this above-guarantee parameterization 
of Vertex Cover is fixed-parameter tractable and can be solved^ in time G*(15^'‘). This 
was first improved to G*(9*'‘) (Raman et ah, ESA 2011), then to (Cygan et ah, 

IPEC 2011, TOCT 2013), then to C>*(2.618'='') (Narayanaswamy et al., STAGS 2012) and 
finally to the current best bound O*(2.3146^'") (Lokshtanov et al., TALC 2014). The last two 
bounds were in fact proven for a different parameter: namely, the excess kx of the solution 
size over LP, the value of the linear programming relaxation of the standard LP formulation 
of Vertex Cover. Since LP > MM for any graph, we have that kx < kf^ for Yes instances. 
This is thus a stricter parameterization—the new parameter is, in general, smaller—and the 
running times carry over directly to the parameter 

We investigate an even stricter parameterization of Vertex Cover, namely the excess k 
of the solution size over the quantity {2LP — MM). We ask: Given a graph G and fc s N as 
input, does G have a vertex cover of size at most {2LP — MM) k? The parameter is k. It 
can be shown that {2LP — MM) is a lower bound on vertex cover size, and since LP > MM 
we have that {2LP — MM) > LP, and hence that k < kx holds for Yes instances. Further, 
{kx — k) could be as large as {LP — MM) and—to the best of our knowledge—this difference 
cannot be expressed as a function of kx alone. These facts motivate and justify our choice 
of parameter: this is indeed a stricter parameterization whose tractability does not follow 
directly from known results. 

We show that Vertex Cover is fixed-parameter tractable for this stricter parameter k: 
We derive an algorithm which solves Vertex Cover in time 0*(3^), thus pushing the enve¬ 
lope further on the parameterized tractability of Vertex Cover. 


^The O* notation hides polynomial factors. 



1 Introduction 


The input to the Vertex Cover problem consists of an undirected graph G and an integer k, 
and the question is whether G has a vertex cover —a subset 5 C 1/ (G) of vertices such that every 
edge in G has at least one end-point in S —of size at most k. This problem is among Karp’s 
original list of 21 NP-complete problems Ill4ll : it is also one of the best-studied problems in the 
field of parameterized algorithms and complexity ll5llT^[T8[|24ll . 

The input to a parameterized version of a classical decision problem consists of two parts: 
the classical input and a specified parameter, usually an integer, usually denoted by the letter 
k. A fixed-parameter tractable (FPT) algorithm IlSlITOll for this parameterized problem is one 
which solves the underlying decision problem in time f{k) ■ where (i) / is a computable 
function of k alone, (ii) n is the size of the (classical) input instance, and (iii) c is a constant 
independent of n and k. This running time is often written as 0*{f{k)); the O* notation hides 
constant-degree polynomial factors in the running time. A parameterized algorithm which has 
an FPT algorithm is itself said to be (in) FPT. 

The “standard” parameter for Vertex Cover is the number k which comes as part of the 
input and represents the size of the vertex cover for which we look—hence referred to, loosely, as 
the “solution size”. This is the most extensively studied parameterization of Vertex Cover IfTl 
l4ll5l [T5l[22l . Starting with a simple two-way branching algorithm (folklore) which solves the 
problem in time 0*{2^) and serves as the de facto introduction-cum-elevator-pitch to the field, 
a number of FPT algorithms with improved running times have been found for Vertex Cover, 
the current fastest of which solves the problem in 0*(1.2738^) time ||5l]. It is also known that 
unless the Exponential Time Hypothesis (ETH) fails, there is no algorithm which solves Vertex 
Cover in time JTSl]. 

This last point hints at a fundamental drawback of this parameterization of Vertex Cover: 
In cases where the size of a smallest vertex cover (called the vertex cover number) of the input 
graph is “large”—say, H(n) where n is the number of vertices in the graph—one cannot hope to 
use these algorithms to find a smallest vertex cover “fast”. This is, for instance, the case when 
the input graph G has a large matching, which is a set of edges of G no two of which share 
an end-point. Observe that since each edge in a matching has a distinct representative in any 
vertex cover, the size of a largest matching in G is a lower bound on the vertex cover number 
of G. So when input graphs have matchings of size H(n) —which is, in a real sense, the most 
common case by far (see, e.g.; [21 Theorem 7.14])—FPT algorithms of the kind described in the 
previous paragraph take H(c’^) time for some constant c, and one cannot hope to improve this 
to the form 0(0°^"^^) unless ETH fails. Put differently: consider the standard parameterization of 
Vertex Cover, and let MM denote the size of a maximum matching—the matching number — 
of the input graph. Note that we can find MM in polynomial time @ . When k < MM the 
answer is trivially No, and thus such instances are uninteresting, and when k > MM, FPT 
algorithms for this parameterization of the problem are impractical for those (most common) 
instances for which MM = Vl{n). 

Such considerations led to the following alternative parameterization of Vertex Cover, 
where the parameter is the “excess” above the matching number: 

Above-Guarantee Vertex Cover (AGVC) Parameter: k^ 

Input: A graph G and k^ € N. 

Question: Does G have a vertex cover of size at most MM + k^l 

The parameterized complexity of AGVC was settled by Razgon and O’Sullivan [25fl in 2008; 
they showed that the problem is FPT and can be solved in time. A sequence of faster 

FPT algorithms followed: In 2011, Raman et al. ||24H improved the running time to 0*(9*’'"), 
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and then Cygan et al. ll^ [ 7 |l improved it further to In 2012, Narayanaswamy et al. IfT^ 

developed a faster algorithm which solved AGVC in time O*(2.618^''). Lokshtanov et al. ifT^ 
improved on this to obtain an algorithm with a running time of (!?*(2.3146^'"). This is currently 
the fastest FPT algorithm for Above-Guarantee Vertex Cover. 

The algorithms of Narayanaswamy et al. and Lokshtanov et al. in fact solve a “stricter” pa¬ 
rameterization of Vertex Cover. Let LP denote the minimum value of a solution to the linear 
programming relaxation of the standard LP formulation of Vertex Cover fSee lSection 2l for def¬ 
initions.). Then LP is a lower bound on the vertex cover number of the graph. Narayanaswamy 
et al. introduced the following parameterization^ of Vertex Cover, “above” LP: 


Vertex Cover Above LP (VCAL) Parameter: kx 

Input: A graph G and kx 

Question: Does G have a vertex cover of size at most LP + /ca? 

The two algorithms solve VCAL in times C)*(2.618^^) and O*(2.3146^^), respectively. Since 
the inequality LP > MM holds for every graph we get that VCAL is a stricter parameteriza¬ 
tion of Vertex Cover, in the sense that these algorithms for VCAL directly imply algorithms 
which solve AGVC in times 0*(2.618^'') and 0*(2.3146^''), respectively. To see this, consider 
an instance {G, k^) of AGVC where MM is the matching number and VGopt is the (unknown) 
vertex cover number of the input graph G, and let x = MM + The question is then whether 
yCopt < X. To resolve this, find the value LP for the graph G (in polynomial time) and set 
kx = X — LP. Now we have that VGopt < x VGopt < LP + kx, and we can check if the 

latter inequality holds—that is, we can solve VCAL—in C)*(2.3146^^) time using the algorithm 
of Lokshtanov et al. Now LP > MM =^> (x — LP) < (x — MM) kx < kp, and so this 
algorithm runs in 0*(2.618^'') time as well. 

This leads us naturally to the next question: can we push this further? Is there an even 
stricter lower bound for Vertex Cover, such that Vertex Cover is still fixed-parameter tractable 
when parameterized above this bound? To start with, it is not clear that a stricter lower bound 
even exists for Vertex Cover: what could such a bound possibly look like? It turns out that we 
can indeed derive such a bound; we are then left with the task of resolving tractability above 
this stricter bound. 

Our Problem. Motivated by an observation of Lovasz and Plummer IITTTI we show—see lLemma H — 
that the quantity {2LP — MM) is a lower bound on the vertex cover number of a graph, and 
since LP > MM we get that (2LP — MM) > LP. This motivates the following parameteriza¬ 
tion of Vertex Cover: 

Vertex Cover Above Lovasz-Plummer (VCAL-P) Parameter: k 

Input: A graph G and G N. 

Question: Does G have a vertex cover of size at most {2LP — MM) + k7 

Since {2LP — MM) > LP we get, following similar arguments as described above, that Ver¬ 
tex Cover Above Lovasz-Plummer is a stricter parameterization than Vertex Cover Above 
LP. Further, {kx — k) could be as large as {LP — MM) and—to the best of our knowledge— 
this difference cannot be expressed as a function of kx alone for the purpose of solving Vertex 
Cover. These facts justify our choice of parameter: Vertex Cover Above Lovasz-Plummer 
is indeed a stricter parameterization than both Above-Guarantee Vertex Cover and Vertex 
Cover Above LP, and its tractability does not follow directly from known results. 

^To be precise, Narayanaswamy et al. used the value [LP] instead of just LP in their definition of Vertex Cover 
Above LP, but this makes no essential difference. 
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Our Results. The main result of this work is that Vertex Cover is fixed-parameter tractable 
even when parameterized above this stricter lower bound: 

Theorem 1. Vertex Cover Above Lovasz-Plummer is fixed-parameter tractable and can be 
solved in 0*(3^) time. 

By the discussions above, this directly implies similar FPT algorithms for the two weaker 
parameterizations: 

Corollary 1. Vertex Cover Above LP can be solved in time, and Above-Guarantee 

Vertex Cover can be solved in C>*(3^'") time. 


Our Methods. We now sketch the main ideas behind our FPT algorithm for Vertex Cover 
Above Lovasz-Plummer; the details are in [Section 31 Let k = {2LP — MM) + k denote the 
“budget”, which is the maximum size of a vertex cover in whose existence we are interested; we 
want to find if there is a vertex cover of size at most k. At its core, our algorithm is a simple 
branching algorithm which (i) manages to drop the measure k by at least 1 on each branch, and 
(ii) has a worst-case branching factor of 3. To achieve this kind of branching we need to find, 
in polynomial time, constant-sized structures in the graph, on which we can branch profitably 
It turns out that none of the “local” branching strategies traditionally used to attack Vertex 
Cover —from the simplest “pick an edge and branch on its end-points” to more involved ones 
based on complicated structures (e.g., those of Chen et al. ||5l) —serve our purpose. All of these 
branching strategies give us a drop in k in each branch—because we pick one or more vertices 
into the solution—but give us no control over how LP and MM change. 

So we turn to the more recent ideas of Narayanaswamy et al. II19H who solve a similar 
problem: they find a way to preprocess the input graph using reduction rules in such a way that 
branching on small structures in the resulting graph would make their measure {k — LP) drop 
on each branch. We find that their reduction rules do not increase our measure, and hence that 
we can safely apply these rules to obtain a graph where we can pick up to two vertices in each 
branch and still have control over how LP changes. The branching rules of Narayanaswamy et 
al., however, are not of use to us: these rules help control the drop in LP, but they provide no 
control over how MM changes. Note that for our measure k to drop we need, roughly speaking, 
(i) a good drop in k, (ii) a small drop in LP, and (iii) a good drop in MM. None of the branching 
strategies of Narayanaswamy et al. or Lokshtanov et al. (or others in the literature which we 
tried) help with this. 

To get past this point we look at the classical Gallai-Edmonds decomposition of the reduced 
graph, which can be computed in polynomial time || ^[TT1[T^I17II . We prove that by carefully 
choosing edges to branch based on this decomposition, we can ensure that both LP and MM 
change in a way which gives us a net drop in the measure k. The key ingredient and the most 
novel aspect of our algorithm—as compared to existing algorithms for Vertex Cover —is the 
way in which we exploit the Gallai-Edmonds decomposition to find small structures—edges 
and vertices—on which we can branch profitably. While this part is almost trivial to implement, 
most of the technical effort in the paper has gone into proving that our choices are correct. See 


Algorithm 1 for an outline which highlights the new parts, and Algorithm 2 on page for the 


complete algorithm. 


2 Preliminaries 

We use i±) to denote the disjoint union of sets. All our graphs are undirected and simple. V{G) 
and E{G) denote, respectively, the vertex and edge sets of a graph G. G[X] is the subgraph of 
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Algorithm 1 An outline of the algorithm for Vertex Cover Above Lovasz-Plummer. 

1 : function VCAL-P((G, fc)) 

2: Exhaustively apply the three reduction rules of Narayanaswamy et al. to {G, k). 

3: Let {G, k) denote the resulting graph on which no rule applies. 

4: if (G, k) is a trivial instance then 

5: return True or False as appropriate. 

6: Compute the Gallai-Edmonds decomposition V (G) = O & I & P of G. 

7: if G[I U P] contains at least one edge {u, v} then 

8: Branch on the edge {u, v}. k drops by 1 on each branch. 

9: else 0 Now P = 0. 

10: Branch on a vertex u G O = V(G) and two of its neighbours v,w G O: 

11: When we pick both of u, ic into the solution in one branch, k drops by 1. 

12: When we pick u into the solution in the other branch, k may not drop. We find a 

suitable edge in G' = (G \ it) and branch on its end-points to make k drop. 


G induced by a vertex subset X C V{G): G[X] = {X,F) ; F = € P(G) ; v,w G X}. 

MM{G) is the matching number of graph G, and OPT{G) is the vertex cover number of G. 
A matching M in graph G saturates each vertex which is an end-point of an edge in M, and 
exposes every other vertex in G. M is a perfect matching if it saturates all of V (G). M is a near¬ 
perfect matching if it saturates all but one vertex of V (G). Graph G is said to be factor-critical if 
for each v G V(G) the induced subgraph G[{V{G) \ {v})] has a perfect matching. 

For X C V{G), N{X) is the set of neighbours of X which are not in X: N{X) = {u G 
(V(G) \X) ] 3w G X : {v,w} G P(G)}. X C V(G) is an independent set in graph G if 
no edge in G has both its end-points in X. The surplus of an independent set X C V(G) is 
surplus(JV) = (|A^(X)| — |vV|). The surplus of a graph G, surplus(G), is the minimum surplus 
over all independent sets in G. Graph G is a bipartite graph if V (G) can be partitioned as 
V{G) = X\PY such that every edge in G has exactly one end point in each of the sets X,Y. 
Hall’s Theorem tells us that a bipartite graph G = {{X tt) Y),E) contains a matching which 
saturates all vertices of the set X if and only if VS* C X : |A^(S)| > |5|. Kdnig’s Theorem tells 
us that for a bipartite graph G, OPTfG) = MM{G). 

The linear programming (LP) relaxation of the standard LP formulation for Vertex Cover 
for a graph G (the relaxed Vertex Cover LPfor G for short), denoted LPVG{G), is: 

minimize ^ 

veviG) 

subject to -I- > 1 , {u, v} G E 

0<x^<l , V gV (G) 

A feasible solution to this LP is an assignment of values to the variables Xy ■, v G V{G) which 
satisfies all the conditions in the LP, and an optimum solution is a feasible solution which mini¬ 
mizes the value of the objective function Y1v<£V{g) w{x) to denote the value (of the 

objective function) of a feasible solution x to LPVG{G), and LP{G) to denote the value of an 
optimum solution to LPVG{G). OPT{G) and MM{G) are then the values of optimum solu¬ 
tions to the integer programs corresponding to LPVG{G) and to its LP dual, respectively |[3l]. 
It follows that for any graph G, MM{G) < LP{G) < OPT{G). Our stronger lower bound for 
OPT{G) is motivated by a similar bound due to Lovasz and Plummer IfTTl Theorem 6.3.3]: 

Lemma 1. For any graph G, OPT{G) > (2LP(G) — MM{G)). 
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Proof. Let 5 be a smallest vertex cover of graph G, and let H = {{S kt) {V{G) \ S)),F) be the 
bipartite subgraph of G with F = {u, v} € E{G) ; u € S,v € (V{G) \ S). That is, the vertex set 
of if is 1/ (G) with the bipartition {S, {V(G) \ S)), and the edge set of H consists of exactly those 
edges of G which have one end-point in S and the other in {V {G)\S). Let T be a smallest vertex 
cover of graph H. Then |r| = OPT{H) = MM{H), where the second equality follows from 
Konig’s Theorem. Consider the following assignment y of values to variables ■, v {G): 


yv = < 


iive{SnT) 

if^; € {{SUT)\{SnT)) 

otherwise. 


Observe that 0 < < 1 for each v G y{G). We claim that y is a feasible solution to 

LPVG{G). Indeed, since S is a vertex cover of G, every edge {m, f} G E{G) must have at 
least one end-point in S. If {u, u} n (5 n T) 7^ 0 then y assigns the value 1 to at least one of 
ym yv, and so we have that yu + VvP 1- Otherwise, if {u, v} F {S \{S n T)) then y assigns the 
value ^ to both of yu,yv, and so we have that yu + yv = ^- In the only remaining case, exactly 
one of {u, u} is in S, and the other vertex is in {V(G) \ S). Without loss of generality, suppose 
{u,v} F S = {u},v G {V{G) \ S). Then {u,v} G E{P[) and u ^ T, hence we get—since T is a 
vertex cover of H —that v &T. Thus {u, v} C ((5 U T) \ (S' n T)), and so y assigns the value ^ 
to both of yu, yv and we have that yu + yv = 1- Thus the assignment y satisfies all the conditions 
in the LPVG{G), and hence is a feasible solution to LPVG{G). Thus w{y) > LP{G). 

Observe now that 

_ 1*^1 + 1^1 _ OPT{G) + OPT{H) _ OPT{G) + MM{H) ^ OPT{G) + MM{G) 

where the first equality follows from the way we defined y, and the inequality follows from the 
observation that the matching number of the subgraph ff of G cannot be larger than that of G 
itself. Putting these together we get that LP{G) < w{y) < opt{g)+mm{g) ^ which in turn gives 
the bound in the lemma. □ 


For any graph G there exists an optimum solution to LPVG{G) in which Xv uG 

V{G) IfZOll . Such an optimum solution is called a half-integral solution to LPVG{G), and we 
can find such a solution in polynomial time |[2T|| . Whenever we refer to an optimum solution 
to LPVG{G) in the rest of the paper, we mean a half-integral solution. Given a half-integral 
solution X to LPVG{G), we define Vf = {v € V{G) ] Xv = i} for each i G {0, 1}. For any 

optimal half-integral solution x we have that N{Vf) = Vf. Given a graph G as input we can, 
in polynomial time, compute an optimum half-integral solution x to LPVG{G) such that for 
the induced subgraph H = G\yfif\, setting all variables to the value ^ is the unique optimum 
solution to LPVC{H) lf2TII . Graphs which satisfy the latter property must have positive surplus, 
and conversely: 

Lemma 2. Il23ll For any graph G, all-^ is the unique optimum solution to LPVG{G) if and only 
ifsurplus(G) > 0. 

In fact, the surplus of a graph G is a lower bound on the number of vertices that we can 
delete from G, and have a guaranteed drop of exactly ^ per deleted vertex in LP{G): 

Lemma 3. Let G be a graph with surplus(G) > s. Then deleting any subset of s vertices from G 
results in a graph G' such that LP{G') = LP{G) — |. 
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Proof. The proof is by induction on s. Let n = |i/(G)|. The case s = 0 is trivially true. Suppose 
s = 1. Thenbv rLemma 2] all-4 is the unique optimum solution to LPVC{G), and so LP{G) = 
Let V € V{G), and let G' = G[y(G)\{r;}]. Then |F(G'| = (n— 1). Since all-i is a feasible solution 
to LPVG{G'), we get that LP{G') < = LP{G) — If possible, let x' be an optimum 

solution for LPVG{G') such that w{x') < ■ From the half-integrality property of relaxed 

Vertex Cover LP formulations we get that w{x') < (§ — 1). Now we can assign the value 
1 to vertex v and the values x' to the remaining vertices of graph G, to get a solution x such 
that w{x) = § = LP{G). Thus x is an optimum solution to LPVG{G) which is not all-i, a 
contradiction. So we get that LP{G') = LP{G) — proving the case s = 1. 

For the induction step, let s > 2. Then bv ILemma 21 all-^ is the unique optimum solution to 
LPVG{G), and so LP(G) = Let v be an arbitrary vertex in G, and let G' = G\y {G) \ {u}]. 
Since deleting a single vertex from G cannot cause the surplus of G to drop by more than 1, we 
get that surplus(G') > (s — 1) > 1. So from ILemma 21 we get that LP{G') = . Applying 

the induction hypothesis to G' and s — 1, we get that deleting any subset of s — 1 vertices from 
G' results in a graph G” such that LP{G") = LP{G') — . This 

completes the induction step. □ 

There is a matching between the vertex sets which get the values 0 and 1 in an optimal 
half-integral solution to the LP. 

Lemma 4. Let G be a graph, and let x be an optimal half-integral solution to LPVG{G). Let 
H = {{Vf 1+) Vq),F) be the bipartite subgraph of G where F = {u,v} € E{G) ; u G Vf,v € Vf. 
Then there exists a (maximum) matching of H which saturates all ofVf. 

Proof It is enough to show that for every X C Vf the inequality |A^(X)| > |X| holds in the 
graph H, and the rest will follow by Hall’s Theorem. So let there exist some X C Vf such that 
|A^(X)| < |X| in H. Now consider a solution x* to LPVG{G) in which all the vertices of G 
have same values as in x, except that all vertices in X U N{X) get the value It is not difficult 
to verify that x* is a feasible solution to LPVG{G). Now w{x*) = w{x) + < w{x), 

which is a contradiction since we assumed that x is a solution to LPVG{G) with the minimum 
value. The lemma follows. □ 

We make critical use of the classical Gallai-Edmonds decomposition of graphs. 

Definition 1 (Gallai-Edmonds decomposition). The Gallai-Edmonds decomposition of a graph 
G is a partition of its vertex set V (G) as V (G) = O i+i / i+i P where: 

• O = {v (G) ; some maximum matching of G leaves v exposed} 

• I = N{0) 

• P = V{G) \ (/UO) 

We now list a few of the many useful properties of Gallai-Edmonds decompositions. 

Theorem 2. ll9l [m[T2l[T7ll The Gallai-Edmonds decomposition of a graph G is unique, and can 
be computed in polynomial time in the size of G. Let V (G) = O tti / i+) P be the Gallai-Edmonds 
decomposition of G. Then the following hold: 

1. Every component of the induced subgraph G[0] is factor-critical. 

2. A matching M in graph G is a maximum matching of G if and only if: 
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(a) For each connected component H of the induced subgraph G[0], the edge set M n E{H) 
forms a near perfect matching of H; 

(b) For each vertex i ^ I there exists some vertex i G O such that {i, o} G M, and; 

(c) The edge set M n E{G[P]) forms a perfect matching of the induced subgraph G[P]. 

3. In particular: Any maximum matching M of G is a disjoint union of (i) a perfect matching 
of G[P], (ii) near-perfect matchings of each component ofG[0], and (Hi) an edge from each 
vertex in I to a distinct component ofG[0]. 

4. The Stability Lemma: For avertexv € V(G) letG — v = G\V{G) \v]. Let 0{H), I{H), P{H) 
denote the three parts in the Gallai-Edmonds decomposition of a graph H. 

• Let V € O. Then 0{G — v) [0\ {u}), I{G — v) Cl, and P(G — v) D P. 

• Let V ^ I. Then 0(G — v) = O, I(G — v) = (I \ { 1 ;})^ and P{G — v) = P. 

• Let ve P. Then 0{G - v) D O, I{G -v)CI, and P{G -v)C{P\ {t;}). 

Corollary 2. Let V{G) = O i±) / i±) P be the Gallai-Edmonds decomposition of graph G. Then the 
following hold: 

1. If I U P is an independent set in G, then P = 0. 

2. Let v,w & O be two vertices which are part of the same connected component of the induced 
subgraph G[0], and let G' = G[{V{G) \ {^;,u;})]. Then MM{G') < {MM{G) - 1). 

Proof We prove each statement. 

1. From the assumption, G'[P] contains no edges. By [Theorem 2[ G'[P] has a perfect match¬ 
ing. Both of these can hold simultaneously only when P = 0. 

2. Let G be the connected component of G[0] which contains both v and w. From part 
(3) of [Theorem 21 we get that any maximum matching of graph G which exposes vertex 
V contains a perfect matching of the subgraph C” = C[{y{G) \ {?;})]. Therefore, every 
maximum matching of G which survives in G" = G[{y{G) \ {?;})] contains a perfect 
matching of G" . It follows that if we delete w G V{G'') as well from G” to get G' , then 
the matching number reduces by at least one, since no perfect matching of C” can survive 
the deletion of vertex w {G"). 


□ 

When the set / U P is independent in a graph of surplus at least 2, we get more properties 
for the set O: 

Lemma 5. Let G be a graph with surplus(G) > 2, and let V{G) = O ^ I ^ P be the Gallai- 
Edmonds decomposition of graph G. If I U P is an independent set in G, then: 

1. There is at least one vertex o ^ O which has at least two neighbours in the set O. 

2. Let V € O be a neighbour of some vertex o € O. Let G' = G[{y (G) \ {o})], and let V {G') = 
O' 1 +) P i±) P' be the Gallai-Edmonds decomposition of graph G'. Then the induced subgraph 
G'[P'] contains at least one edge. 

Proof We prove each statement. 
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1. Each component of G[0] is factor critical (iTheorem 21) . and so has an odd number of 
vertices. So to prove this part it is enough to show that there is at least one component in 
G[0] which has at least two (and hence, at least three) vertices. Suppose to the contrary 
that each component in G[0] has exactly one vertex. Then the set O is an independent 
set in graph G. Since the set / U P is independent by assumption, we get from 
that P = 0. Thus G is a bipartite graph with O and I being two parts of the 
In particular, N{0) C I and N{I) C O both hold. But since surplus(G) > 2 this implies 
that both |/| > (|0| + 2) and \0\ > (|/| + 2) hold simultaneously, which cannot happen. 
The claim follows. 

2. Observe that by the definition of the set O, we have that MM{G') = MM{G). If G'[P'] 
contains no edge, then the fact that G[P'] has a perfect matching (ITheorem 2D implies 
that P' = 0. Together with the Stability Lemma (see lTheorem~2l) this implies that v ^ O' 
in graph G'. Then by the definition of the set O' there is a maximum matching MM' 
of G' which exposes the vertex v. But then the matching MM' together with the edge 
{o,v} forms a matching in graph G of size MM{G') + 1 = MM{G) + 1, a contradiction. 
Therefore G'[P'] must contain at least one edge. 


Corollary 2 
bipartition. 


□ 


3 The Algorithm 

In this section we describe our algorithm which solves Vertex Cover Above Lovasz-Plummer 
in 0*{3^) time. We start with an overview of the algorithm. We then state the reduction and 
branching rules which we use, and prove their correctness. We conclude the section by proving 
that the algorithm correctly solves Vertex Cover Above Lovasz-Plummer and that it runs 
within the stated running time. 


3.1 Overview 

The Vertex Cover Above Lovasz-Plummer problem can be stated as: 


Parameter: k 


Vertex Cover Above Lovasz-Plummer (VCAL-P) 

Input: A graph G and fc e N. 

Question: Let k = (2LP(G) - MM{G)) + k. Is OPT{G) < kl 

At its core the algorithm is a simple branching algorithm. Indeed, we employ only two basic 
branching steps which are both “natural” for Vertex Cover: We either branch on the two end¬ 
points of an edge, or on a vertex v and a pair u, w of its neighbours. We set k as the measure 
for analyzing the running time of the algorithm. We ensure that this measure decreases by 1 in 
each branch of a branching step in the algorithm. Since OPT{G) > {2LP{G) — MM{G)) for 
every graph G —See ILemma 11 —and k > OPT{G) holds—by definition—for a Yes instance, it 
follows that k = {k + MM{G) — 2LP{G)) is never negative for a Yes instance. Hence we can 
safely terminate the branching at depth k. Since the worst-case branching factor is three, we 
get that the algorithm solves VCAL-P in time 0*(3^). 


The algorithm—see Algorithm 2 on page [9] —modifies the input graph G in various ways as 
it runs. In our description of the algorithm we will sometimes, for the sake of brevity, slightly 
abuse the notation and use G to refer to the “current” graph at each point in the algorithm. 
Since the intended meaning will be clear from the context, this should not cause any confusion. 
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Algorithm 2 The 0 *( 3 ^) FPT algorithm for Vertex Cover Above Lovasz-Plummer. 


1: function VCAL-P((G, k, reduce)) > Initially invoked with reduce == True. 

2: k^{2LP{G)-MM{G))+k 

3: if reduce == True then > Do the preprocessing only if reduce is True. 

4: while At least one of Reduction Rules 1, 2, and 3 applies to {G, k) do 

5: Apply the^rst such rule to {G, k), to get (G', k'). 

6: G^G',k^ k’ 


G^G',k^k' 

k^k + MM{G) - 2LP{G) 


> Renaming for brevity 
i> Preprocessing ends. 


if < 0 then 
return False 

else if G has no vertices then 
return True 


> Check for the base cases. 


Compute the Gallai-Edmonds decomposition V(G) = O i±l / i±i P of G. 


if G[I U P] contains at least one edge {u, r} then > Brar 

Gi^(G\u),G2^(G\r) 
k^{k-l) 

h = {k + MM{Gi) - 2LP(Gi)), k2 = {k + MM(G2) - 2LP{G2)) 
return (VCAL-P(Gi, fei, True) V VCAL-P(G 2 , k 2 ,True)) 


> Branch on edge {u, r}. 


0 Since / U P is independent, P = 


Choose a vertex u ^ O and two of its neighbours v,w G O. 

> Such vertices must exist. 

Gi ^ (G \ tt) > Pick u in the solution. 

k <— {k — 1) 

h = {k + MM{Gi) - 2LP(Gi)), 

if VCAL-P(Gi, fei, Pa/se)==True then > No reduction rule will be applied now. 

return True 

else 0 Pick both v and w in the solution. 

G2^(G\{r,u;}) 

A: (/c — 1) i> Effectively reducing k by two. 

k2 = {k + MM(G2) - 2LP(G2)) 
return VCAL-P(G 2 , k 2 ,True) 


> Effectively reducing k by two. 


The crux of the algorithm is the manner in which it finds in G a small structure—such as an 
edge—on which to branch such that the measure k drops on each branch. Clearly, picking an 
arbitrary edge—say—and branching on its end-points will not suffice: this will certainly reduce 
the budget k by one on each branch, but we will have no guarantees on how the values MM{G) 
and LP{G) change, and so we cannot be sure that k drops. Instead, we apply a two-pronged 
strategy to find a small structure in the graph which gives us enough control over how the 
values k, MM{G), LP{G) change, in such a way as to ensure that k = {k + MM{G) — 2LP(G)) 
drops in each branch. 
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First, we employ a set of three reduction rules which give us control over how LP{G) 
changes when we pick a vertex into the solution and delete it from G. These rules have the 
following nice properties: 

• Each rule is sound—see Isubsection 3 .21 —and can be applied in polynomial time; 

• Applying any of these rules does not increase the measure k, and; 

• If none of these rules applies to G, then we can delete up to two vertices from G with an 
assured drop of 0.5 per deleted vertex in the value of LP{G). 

In this we follow the approach of Narayanaswamy et al. IfT^ who came up with this strategy to 
find a small structure on which to branch so that their measure—which was {k — LP) —would 
reduce on each branch. Indeed, we reuse three of their reduction rules, after proving that these 
rules do not increase our measure k. 

While these rules give us control over how LP{G) changes when we delete a vertex, they 
do not give us such control over MM{G). That is: let G be a graph to which none of these 
rules applies and let be a vertex of G. Picking v into a solution and deleting it from G to 
get G' would (i) reduce k by 1, and (ii) make LP{G') = LP{G) — 0.5, but will not result in a 
drop in k if it so happens that the matching number of G' is the same as that of G. Thus for our 
approach to succeed we need to be able to consistently find, in a graph reduced with respect to 
the reduction rules, a small structure—say, an edge—on which to branch, such that deleting a 
small set of vertices from this structure would reduce the matching number of the graph by at 
least 1. 

The search for such a structure led us to the second and novel part of our approach, namely 
the use of the classical Gallai-Edmonds decomposition of graphs (iDefinition ll) . We found that 
by first reducing the input graph with respect to the three reduction rules and then carefully 
choosing edges to branch based on the Gallai-Edmonds decomposition of the resulting graph, 
we could make the measure k drop on every branch. We describe the reduction and branching 
rules in the next two subsections. 

3.2 The Reduction Rules 

Given an instance (G, k) of Vertex Cover Above Lovasz-Plummer our algorithm first com¬ 
putes the number k = (2LP(G) — MM{G) + k) so that {G,k) is the equivalent instance of 
(classical) Vertex Cover. Each of our three reduction rules takes an instance (G = {V,E),k) 
of Vertex Cover, runs in polynomial time, and outputs an instance (G' = {V',E'),k') of Ver¬ 
tex Cover. We say that a reduction rule is sound if it always outputs an equivalent instance. 
That is, if it is always the case that G has a vertex cover of size at most k if and only if G' has 
a vertex cover of size at most k'. We say that a reduction rule is safe if it never increases the 
measured That is, if it is always the case that k'+MM{G') — 2LP{G') < k+MM{G) — 2LP{G). 

In the algorithm we apply these reduction rules exhaustively, in the order they are pre¬ 
sented. That is, we take the input instance (G, k) and apply the first among [Reduction Rule ll 
[Reduction Rule 21 and [Reduction Rule 3! which applies —see definitions below—to {G,k) to ob¬ 
tain a modified instance {G',k'). We now set G ^ G',k ^ k' and repeat this procedure, till 
none of the rules applies to the instance (G, k). We say that such an instance is reduced with 
respect to our reduction rules. The point of these reduction rules is that they help us push the 
surplus of the input graph to at least 2 in polynomial time, while not increasing the measure k. 

Reduction Rule 1. Compute an optimal solution x to LPVC(G) such that all-^ is the unique 
optimum solution to 'LW(Z{_G\Vfif\). Set G' = G\yfif\,k' = k — \Vf\. 
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iReduction Rule ll apylies to {G, k) if and only if all-^ is not the unique solution to LPVC(G). 

Reduction Rule 2. If there is an independent set Z C V{G) such that surplus(Z) = 1 and 
N{Z) is not an independent set in G, then set G' = G\{Z U N{Z)), k' = k — \N{Z)\. 

IReduction Rule 2\ applies to (G, k) if and only if (i) IReduction Rule II does not apply, and (ii) G 
has a vertex subset Z with the properties stated in IReduction Rule~^ 

Reduction Rule 3. If there is an independent set Z C V{G) such that surplus(Z) = 1 and 
N{Z) is an independent set in G, then remove Z from G and identify the vertices of N{Z )— 
that is, delete all of N{Z), add a new vertex z, and make z adjacent to all vertices of the set 
{N{N{Z)) \ Z )—to get G', and set k' = k — \Z\. 

IReduction Rule 3 1 applies to (G, k) if and only if (i) neither of the previous rules applies, and (ii) 
G has a vertex subset Z with the properties stated in IReduction Rule~3l 

All our reduction rules are due to Narayanaswamy et al. |fT9l Preprocessing Rules 1 and 
2]. The soundness of these rules and their running-time bounds also follow directly from their 
work. We need to argue, however, that these rules are safe for our measure k. 

Lemma 6. II19II All the three reduction rules are sound, and each can be applied in time polyno¬ 
mial in the size of the input {G, k). 

It remains to show that none of these reduction rules increases the measure k = k + 
MM{G) — 2LP{G). That is, let {G = {V,E),k) be an instance of Vertex Cover to which 
one of these rules applies, and let {G' = {V, E'), k') be the instance obtained by applying the 
rule to (G, k). Then we have to show, for each rule, that k' = k' + MM{G') — 2LP{G') < k 
holds. We establish this by examining how each rule changes the values k, MM and LP. In 
each case, let x be an optimum half-integral solution to LPVC{G) such that all-^ is the unique 
optimum solution to LPVG{G\yfif\), and let LP{G) be the (optimum) value of this solution. 
Also, let x' be an optimum half-integral solution to LPVC{G'), and let LP{G') be the value of 
this solution. 

Lemma 7. \Reduction Rule 1 1 is safe. 

Proof From the definition of the rule we get that k' = k — \ Vf\. Now since x' = ^ is the unique 
optimum solution to LPVG{G'), and G' = G\Vfif[, we get that LP{G') = LP{G) — |Vf|, and 
hence that 2LP{G') = 2LP{G) — 2|V]*|. From iLemma 41 and the construction of the graph G' 
we get that MM{G) > MM{G') + \Vf\, and hence that MM{G') < MM{G) — \Vf\. Putting 
these together, we get that k' <k. □ 

Lemma 8. \Reduction Rule 2\ is safe. 

Proof From the definition of the rule we get that k' = k — \N{Z)\. We bound the other two 
quantities. 

Claim 1. LP(G') > LP{G) - \N{Z)\ + i. 

Proof of the claim. Since Induction Rule II did not apply to {G,k) we know that all-^ is the 
unique optimum solution to LPVG{G). It follows from this and the construction of graph 
G' that LP{G') = = LP{G) - ^(1^1 + \NiZ)\) + - \Vf'\). Adding and 

subtracting i(|iV(Z)|), we get LP{G') = LP{G) - \N{Z)\ + i(|iV(Z)| - \Z\) + i(|Vf'| - \Vf'\) = 
LP{G) - \N{Z)\ + \{\N{Z)\ + iVf'l) - |(|Z| + |Vo"'|). Now since V{G') = (V(G) \ (Z U N{Z))) 
and Vff' C V(G'), we get that Z U Vf' is an independent set in G, and that N(Z U Vf') = 
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N{Z) U Vi in G (Recall that N{Vq) = Vf for any half-integral optimal solution x.). Since 
surplus(G) > 1— [Lemma 3 —we get that in G, \N{Z U Vq')\ — |Z U Vq'\ > 1, which gives 
(|iv(z)| + If/f'l) - (jZj + |L-'|) > 1, and so we get that \{\N{Z)\ + |y-'|) - i(|Z| + |L-'|) > i. 
Substituting this in the equation for LP{G'), we get that LP{G') > LP{G) — \N{Z) \ + 5 . □ 

Now we bound the drop in MM(G). 

Claim 2. MM{G') < MM{G) - |Z|. 

Proof of the claim. Consider the bipartite graph G obtained from the induced subgraph U 
N{Z)] of G by deleting every edge which has both endpoints in N{Z). Observe that since 
surplus(Z) = 1 in G, we get that |A^(X)| > |X| + 1 VX C Z, both in G and in G. Hence by 
Hall’s Theorem we get that G contains a matching saturating Z, and hence that MM{G) = iZj. 
But from the construction of graph G' we get that MM{G) > MM{G') + MM{G). Substituting 
for MM{G), we get that MM{G') < MM{G) - jZj. □ 

Putting all these together, we get that k' = k' + MM(G') — 2LP{G') < {k — \N{Z)\) + 
{MM{G) - \Z\) - 2{LP{G) - \N{Z)\ + l) = k + MM{G) - 2LP{G) + {\N{Z)\-\Z\-l) = k + 
MM{G)—2LP{G) = k, where the last-but-one equality follows from the fact that surplus(Z) = 
1. Thus we have that k' <k. □ 

Lemma 9. \Reduction Rule 3h s safe. 

Proof From the definition of the rule we get that k' = k — \Z\. We bound the other quantities. 
Let z be the vertex in G' which results from identifying the vertices of A^(Z) as stipulated by the 
reduction rule. 

Claim 3. LP{G') > LP{G) - |Z|. 

Proof of the claim. Suppose not. Then we get—from the half-integrality property of the relaxed 
LP for Vertex Cover —that LP{G') < LP{G) — \Z\ — We show that this inequality leads 
to a contradiction. We consider three cases based on the value of xfz), which must be one of 
{0, 1}. Recall that surplus(Z) = 1 and so \N{Z)\ = \Z\ + 1. 

Case 1: x'(z) = 1. Consider a function x" : V —)• {0, 1} defined as follows. For every vertex v 

in y \ {z}, x" retains the value assigned by x'; that is, x''{v) = x'{v). For every vertex v in 
the set N{Z), set x'fv) = 1 and for every vertex v in the set Z, x"{v) = 0. It is not difficult 
to check that x" is a feasible solution to the relaxed Vertex Cover LP for G. But now 
the value of this solution, w{x") = LP{G') — x'{z) + \N{Z)\ = LP{G') — 1 + {\Z\ + 1) < 
LP{G) — Thus x" is a feasible solution for G whose value is less than that of the optimal 
solution, a contradiction. 

Case 2: xfz) = 0. Now consider the following function x" : V ^ {0, 1}. For every vertex v 

in V' \ {z}, x" retains the value assigned by x': x"{v) = x'{v). For every vertex v ^ Z set 
x"{v) = 1 and for every vertex v G N{Z), set x"{v) = 0. It is again not difficult to check 
that x" is a feasible solution to the relaxed Vertex Cover LP for G. And the value of this 
solution, w{x") = LP{G') + |Z| < LP{G) — again a contradiction. 

Case 3: x'{z) = Consider again a function x" : V —^ {0, 1}, defined as follows. For every 

vertex x in V' \ {z}, x ”—once again—retains the value assigned by x'; x''{v) = x'{v). 
For every vertex x € (Z U N{Z)), set x"(x) = This is once again easily verified to 
be a feasible solution to the relaxed Vertex Cover LP for G, and its value is w{x") = 
LP{G’) - x'iz) + i(|Z| + |iV(Z)|) = LP{G’) - i + i(|Z| + \Z\ + 1) < LP(G) - i, once 
again a contradiction. 
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Thus our contrary assumption leads to a contradiction in all possible cases, and this proves the 
claim. □ 

Now we bound the drop in MM(G'). 

Claim 4. MM{G') < MM{G) - |Z|. 

Proof. For an arbitrary vertex u G N{Z), let Gu be the bipartite subgraph G[Z U {N{Z) \ {n})], 
which is an induced subgraph of G. Since surplus(Z) = 1 in G and only one vertex from N{Z) 
is missing in Gu, we get that |A^(X)| > |X| \/X C Z holds in Gu- Hence by Hall’s Theorem we 
get that Gu contains a matching saturating Z, and hence that MM{Gu) = iZj. 

Now consider a maximum matching MM' of G'. Starting with MM' we can construct a 
matching MM" of size \MM'\ in the original graph G which saturates at most one vertex of 
N(Z) and none of Z, as follows: There is at most one edge in MM' which saturates the vertex 
z. If there is no edge in MM' which saturates the vertex z, then we set MM" = MM'. It is not 
difficult to see that MM" saturates no vertex in Z U N{Z). If there is an edge {z,v} € MM', 
then we pick an arbitrary vertex u G N(Z) such that {tt, is an edge in G — such a vertex must 
exist since the edge {z,v} exists in G'. We set MM" = {MM' \ {{.z, u}}) U {{n, u}}. It is not 
difficult to see that MM" is a matching in G which saturates exactly one vertex —u G N{Z) — in 
ZUN{Z). 

If the matching MM", constructed as above, does not saturate any vertex of N{Z), then 
we choose u to be an arbitrary vertex of A^(Z). If MM" does saturate a vertex of A^(Z), then 
we set u to be that vertex. In either case, the union of MM" and any maximum matching of 
the induced bipartite subgraph Gu is itself a matching of G, of size MM{Gu) + MM{G') = 
\Z\ + MM{G'). It follows that MM(G) > |Z|+ MM(G'), which implies MM{G') < MM{G) — 
\Z\. □ 

Putting all these together, we get that fe' = k' + MM{G') — 2LP{G') < {k — \Z\) + {MM{G) — 
\Z\) - 2{LP{G) - \Z\) = k + MM{G) - 2LP{G) = k. Thus we have that k' <k. □ 

Observe that if surplus(G) = 1 then at least one of [Reduction Rule~^ and iReduction Rule 31 
necessarily applies. From this and lLemma 21 we get the following useful property of graphs on 
which none of these rules applies. 

Lemma 10. None of the three reduction rules applies to an instance (G, k) of Vertex Cover if 
and only i/surplus(G) > 2. 

Summarizing the results of this section, we have: 

Lemma 11. Given an instance (G, k) of Vertex Cover Above Lovasz-Plummer we can, in time 
polynomial in the size of the input, compute an instance {G', k') such that: 

1. The two instances are equivalent: G has a vertex cover of size at most {2LP{G)—MM{G))+k 
if and only if G' has a vertex cover of size at most {2LP{G') — MM{G')) + k'; 

2. k' < k, and surplus(G') > 2 . 

3.3 The Branching Rules 

Let (G = {V, E), k) be the instance of Vertex Cover obtained after exhaustively applying the 
reduction rules to the input instance, and let k = k + MM{G) — 2LP{G). Then surplus(G) > 2. 
If < 0 then the instance {G,k) of VCAL-P is trivially a No instance fSee [subsection 3^ . 
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and we return No and stop. In the remaining case k>0, and we apply one of two branch¬ 
ing rules to the instance to reduce the measure k. Each of our branching rules takes an in¬ 
stance {G, k) of VCAL-P, runs in polynomial time, and outputs either two or three instances 
(Gi, fci), (G 2 , k 2 )[, (G 3 , fcs)] of VCAL-P. The algorithm then recurses on each of these instances 
in turn. We say that a branching rule is sound if the following holds: (G, k) is a Yes instance 
of VCAL-P if and only if at least one of the (two or three) instances output by the rule is a YES 
instance of VCAL-P. We now present the branching rules, prove that they are sound, and show 
that the measure k drops by at least 1 on each branch of each rule. 

Before starting with the branching, we compute the Gallai-Edmonds decomposition of the 
graph G = {V, E). This can be done in polynomial time II17II and yields a partition of the vertex 
set V into three parts V = O tt) / i±) P, one or more of which may be empty—see iDefinition 1[ 
We then branch on edges in the graph which are carefully chosen with respect to this partition. 


Branching Rule 1 applies to the graph G if and only if the induced subgraph (G[/ UP]) contains 


at least one edge. 


Branching Rule 1. Branch on the two end-points of an edge {u,v} in the induced subgraph 
(G[/ U Pj). More precisely, the two branches generate two instances as follows: 

Branch 1: Gi ^ (G \ {«}), fci ^ (fe - 1), ki ^ fci + MM(Gi) - 2PP(Gi) 


Branch 2: Ga ^ (G \ {r;}), fea ^ (A: - 1), 4 ^ fea + MM(Ga) - 2 LP(G 2 ) 
This rule outputs the two instances (Gi, fci) and (Ga, fca)- 


Branching Rule 2 applies to graph G if and only if Branching Rule 1 does not apply to G. 


Branching Rule 2. Pick a vertex rt e O of G which has at least two neighbours v,w € O. 
Construct the graph G' = G \ {u} and compute its Gallai-Edmonds decomposition O' tt) /' U P'. 
Pick an edge {x, y} in G' [P'j. The three branches of this branching rule generates three instances 
as follows: 


Branch 1: Gi ^ (G \ {r;, rc}), fci ^ {k-2),ki ^ fei + MM(Gi) - 2LP(Gi) 


Branch 2: Ga ^ (G' \ {x}), k 2 ^ {k - 2), fca ^ fea + MM(G 2 ) - 2 LP(G 2 ) 


Branch 3: G 3 ^ (G' \ {y}), k^ ^ {k - 2), 4 ^ ^3 + MMiGs) - 2LP{G^) 
This rule outputs the three instances (Gi, fci), (Ga, fca), and (G 3 , k^). 


Note that in the pseudocode of Algorithm 2 we have not, for the sake of brevity, written out 
the three branches of the second rule. Instead, we have used a boolean switch {reduce) as a 
third argument to the procedure to simulate this behaviour. 


Lemma 12. Both branching rules are sound, and each can be applied in time polynomial in the 
size of the input (G, k). 


Proof We first prove that the rules can be applied in polynomial time. Recall that we can 
compute the Gallai-Edmonds decomposition of graph G in polynomial time IfTTlI . 


Branching Rule 1 : Eollows more or less directly from the definition of the branching rule. 


Branching Rule ^ It is not difficult to see that the applicability of this rule can be checked 


in polynomial time. If the rule does apply, then the set P is empty and the set I is an 
independent set in G ( Gorollary 2 ). Bv ILemma 51 there is at least one vertex in the set O 
which has at least two neighbours in O. Hence vertices u,v,w of the kind required in the 
rule necessarily exist in G. Erom ILemma 5 1 we also get that an edge {x, y} of the required 
kind also exists. Given the existence of these, it is not difficult to see that the rule can be 
applied in polynomial time. 
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We now show that the rules are sound. Recall that a branching rule is sound if the following 
holds: any instance (G, k) of VCAL-P is a Yes instance if and only if at least one of the instances 
obtained by applying the rule to (G, fe) is a Yes instance. 


Branching Rule l| The soundness of this rule is not difficult to see since it is a straightfor¬ 
ward branching on the two end-points of an edge. Nevertheless, we include a full argu¬ 
ment for the sake of completeness. So let (G, k) be a Yes instance of VCAL-P, and let 


(Gi, fci), (G 2 , A: 2 ) be the two instances obtained by applying Branching Rule 1 to {G,k). 
Since (G, k) is a Yes instance, the graph G has a vertex cover, say S, of size at most 
k = 2LP{G) — MM{G) + k. Then {S n {w, f}) ^ 0. Suppose u € S. Then Si = S \ {tt}) 
is a vertex cover of the graph Gi = G \ {u}, of size at most ki = {k — 1). It follows that 
for ki = ki + MM(Gi) — 2LP(Gi), (Gi,fci) is a Yes instance of VCAL-P. A symmetric 
argument gives us the Yes instance (G 2 , ^ 2 ) of VCAL-P for the case v G S. 

Conversely, suppose (Gi,A:i) is a Yes instance of VCAL-P where Gi = G \ {u},ki = 
{k — 1), ki = ki + MM(Gi) — 2LP(Gi). Then graph Gi has a vertex cover, say Si, of size 
at most ki = {k — 1). S = Si Li {«} is then a vertex cover of graph G of size at most k, 
and so {G,k), where k = k + MM{G) — 2LP{G) is a Yes instance of VCAL-P as well. 
An essentially identical argument works for the case when (G 2 , A: 2 ) is a Yes instance of 
VCAL-P. 


Branching Rule ^ It is not difficult to see that this rule is sound, either, since it consists of 
exhaustive branching on a vertex u. We include the arguments for completeness. So 
let {G,k) be a Yes instance of VCAL-P, and let (Gi,/ci), (G 2 , ^ 2 ), (<-^ 2 , ^ 2 ) be the three 
instances obtained by applying Branching Rule 2 to (G, k). Since (G, k) is a Yes instance, 
the graph G has a vertex cover, say S, of size at most k = 2LP{G) — MM{G) + k. We 
consider two cases: u G S, and u ^ S. First consider the case u ^ S. Then all the 
neighbours of u must be in S. In particular, {v, rc} C S. It follows that the set S \ {v, rc} 
is a vertex cover of the graph Gi = (G \ {u, tc}), of size at most ki = (A; — 2). Hence we 
get that for ki = ki + MM(Gi) — 2LP(Gi), {Gi,ki) is a Yes instance of VCAL-P. 


Now consider the case u G S. Then the set S' = S \ {tt} is a vertex cover of the graph 
G' = G \ {tt}, of size at most A: — 1. Since {x, y} is an edge in the graph G', we get that 
{S' n {x, y}) / 0. Suppose x G S'. Then S 2 = {S' \ {x}) is a vertex cover of the graph 
G 2 = G'\{x}, of size at most A ;2 = {k—2). It follows that for aJ 2 = k2+MM{G2)—2LP{G2), 
(^ 2 ,^ 2 ) is a Yes instance of VCAL-P. A symmetric argument gives us the Yes instance 
(G 3 , ks) of VCAL-P for the case y G S. 

Conversely, suppose (Gi,A:i) is a Yes instance of VCAL-P where Gi = G \ {v,w},ki = 
{k — 2),ki = ki + MM(Gi) — 2LP(Gi). Then graph Gi has a vertex cover, say Si, of 
size at most ki = {k — 2). S' = S'! U {x,tc} is then a vertex cover of graph G of size at 
most k, and so (G, k) where k = k -G MM{G) — 2LP{G), is a Yes instance of VCAL-P as 
well. Essentially identical arguments work for the cases when (G 2 , A; 2 ) or (G 3 , k^) is a Yes 
instance of VCAL-P. 


□ 

Our choice of vertices on which we branch ensures that the measure drops by at least one 
on each branch of the algorithm. 

Lemma 13. Let {G,k) be an input given to one of the branching rules, and let {Gi,ki) be an 
instance output by the rule. Then h<{k- 1). 
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Proof. Recall that by definition, k = k + MM{G) — 2LP{G). We consider each branching rule. 
We reuse the notation from the description of each rule. 


Branching Rule 1: Consider Branch 1. Since u e (I U P), every maximum matching of graph 


G saturates vertex u (iTheorem 2D . Hence we get that MM{Gi) = {MM{G) — 1). Since 
surplus(G) > 2 we get—from ILemma 31 —that LP{Gi) = {LP{G) — |). And since ki = 
{k — 1) by definition, we get that ki = ki+MM{Gi) — 2LP{Gi) = {k — l) + {MM{G) — l) — 
2{LP{G) — ^) = k + MM{G) — 2LP{G) — 1 = (fc — 1). An essentially identical argument 
applied to the (symmetrical) Branch 2 tells us that k 2 = {k — 1). 


Branching Rule ^ Consider Branch 1. Since {u,v^w} C O and v.,w are neighbours of vertex 
u, we get that vertices v and w belong to the same connected component of the induced 
subgraph G[0\ of G. It follows ( [Corollary 2^ that MM{Gi) < {MM{G) — 1). Since 
surplus(G) > 2 and Gi = G \ {v, w} we get—from ILemma 31 —that LP{Gi) = {LP{G) — 
1). And since ki = {k — 2) by definition, we get that ki = ki + MM{Gi) — 2LP{Gi) < 
{k-2) + {Mm[g) - 1) - 2{LP{G) -l) = k + MM{G) - 2LP{G) -l = {k-l). 

Now consider Branch 2. Since u & O we get—from the definition of the Gallai-Edmonds 
decomposition—that MM{G') = MM{G). Now since x € P' we get— ITheorem"^ —that 
MM{G 2 ) = (MM(G') - 1) = {MM{G) - 1). Since surplus(G) > 2 and G 2 = G \ {u,x} 
we get—from ILemma 3i —that LP{G 2 ) = {LP{G) — l). And since k 2 = {k — 2) by definition, 
we get that k 2 = k 2 + MM{G 2 ) - 2LP{G2) = {k-2) + {MM{G) - 1) - 2{LP{G) - 1) = 
k + MM{G) — 2LP{G) — 1 = (k — 1). An essentially identical argument applied to the 
(symmetrical) Branch 3 tells us that ks = {k — 1). 


□ 


3.4 Putting it All Together: Correctness and Running Time Analysis 

The correctness of our algorithm and the claimed bound on its running time follow more or less 
directly from the above discussion. 


Proof of fTheorem Jl We claim that Algorithm 2 solves Vertex Cover Above Lovasz-Plummer 
in 0*(3^) time. The correctness of the algorithm follows from the fact that both the reduction 
rules and the branching rules are sound— ILemma 6 l and ILemma 12l This means that (i) no 
reduction rule ever converts a Yes instance into a No instance or vice versa, and (ii) each 
branching rule outputs at least one Yes instance when given a Yes instance as output, and all 
No instances when given a No instance as input. It follows that if the algorithm outputs Yes or 
No, then the input instance must also have been Yes or No, respectively. 

The running time bound follows from three factors. Firstly, all the reduction rules are safe, 
and so they never increase the measure k —see ILemma 7l ILemma 8l ILemma 9[ and ILemma TTl 
Also, each reduction rule can be executed in polynomial time, and since each reduction rule 
reduces the number of vertices in the graph by at least one, they can be exhaustively applied in 
polynomial time. Secondly, each branch of each branching rule reduces the measure by at least 
1— ILemma l3] —from which we get that each path from the root of the recursion tree—where 
the measure is the original value of k —to a leaf—where the measure first becomes zero or less— 
has length at most k. Further, the largest branching factor is 3, which means that the number 
of nodes in the recursion tree is 0(3^). Thirdly, we know that the computation at each node in 
the recursion tree takes polynomial time. This follows from ILemma 121 for the nodes where we 
do branching. As for the leaf nodes: Since we know that the measure will never be negative 
for a Yes instance (ILemma ID . since we can check for the applicability of each branching rule 
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in polynomial time, and since each branching rule reduces the measure by at least one, we can 
solve the instance at each leaf node in polynomial time. □ 


4 Conclusion 

Motivated by an observation of Lovasz and Plummer, we derived the new lower bound 2LP(G) — 
MM{G) for the vertex cover number of a graph G. This bound is at least as large as the 
bounds MM{G) and LP{G) which have hitherto been used as lower bounds for investigating 
above-guarantee parameterizations of Vertex Cover. We took up the parameterization of the 
Vertex Cover problem above our “higher” lower bound 2LP{G) — MM{G), which we call 
the Lovasz-Plummer lower bound for Vertex Cover. We showed that Vertex Cover remains 
fixed-paramter tractable even when parameterized above the Lovasz-Plummer bound. The main 
result of this work is an 0*(3^) algorithm for Vertex Cover Above Lovasz-Plummer. 

The presence of both {—2LP{G)) and MM{G )—in addition to the “solution size”—in our 
measure made it challenging to find structures on which to branch; we had to be able to con¬ 
trol each of these values and their interplay in order to ensure a drop in the measure at each 
branch. The main new idea which we employed for overcoming this hurdle is the use of the 
Gallai-Edmonds decomposition of graphs for finding structures on which to branch profitably. 
The main technical effort in this work has been expended in proving that our choice of ver¬ 
tices/edges from the Gallai-Edmonds decomposition actually work in the way we want. Note, 
however, that the branching rules themselves are very simple; it is only the analysis which is 
involved. 

The most immediate open problem is whether we can improve on the base 3 of the EPT 
running time. Note that any such improvement directly implies EPT algorithms of the same 
running time for Above-Guarantee Vertex Cover and Vertex Cover Above LP. Tempted by 
this implication, we have tried to bring this number down but, so far, in vain. Another question 
which suggests itself is: Is this the best lower bound for vertex cover number above which 
Vertex Cover is EPT? How far can we push the lower bound before the problem becomes 
intractable? 
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